#### PATENT ABSTRACTS OF JAPAN

(11) Publication number: 2002051072 A

(43) Date of publication of application: 15.02.02

(51) Int. CI

H04L 12/56

(21) Application number: 2000234075

(22) Date of filing: 02.08.00

(71) Applicant:

**FUJITSU LTD** 

(72) Inventor:

**KOJIMA YUJI** 

TSURUOKA TETSUAKI UMEZAKI YASUYUKI SHIMOZONO YOSHITOMO

### (54) PACKET PROCESSING PROCESSOR

#### (57) Abstract:

PROBLEM TO BE SOLVED: To provide a packet processing processor that can process packets at high speed and process packets with instruction procedures whose number is independently of the data length of the packets.

SOLUTION: The packet processing processor 100 consists of a packet access device 110, an intermediate data transfer device 120, a selection signal generating section 130, and instruction procedure execution section 140, 150, 160. Upon the receipt of a packet arrival signal externally, the selection signal generating section 130 outputs an individual selection signal to the 3 instruction procedure execution section 140, 150, 160 selectively and circulatingly. Each instruction procedure execution section receiving the individual selection signal starts prescribed packet processing to a received packet.

COPYRIGHT: (C)2002,JPO



#### (19)日本国特許庁(JP)

# (12) 公開特許公報(A)

(11)特許出顯公開番号 特開2002-51072 (P2002-51072A)

(43)公開日 平成14年2月15日(2002.2.15)

(51) Int.Cl.7

識別記号

FΙ

テーマコート\*(参考)

H04L 12/56

H 0 4 L 11/20

102Z 5K030

#### 審査請求 未請求 請求項の数5 OL (全 15 頁)

| (21)出願番号 | 特顧2000-234075(P2000-234075) | (71) 出願人 000005223             |
|----------|-----------------------------|--------------------------------|
| (22)出顧日  | 平成12年8月2日(2000.8.2)         | 富士通株式会社<br>神奈川県川崎市中原区上小田中4丁目1番 |
|          |                             | 1号                             |
|          |                             | (72)発明者 小島 祐治                  |
|          |                             | 神奈川県川崎市中原区上小田中4丁目1番            |
|          |                             | 1号 富士通株式会社内                    |
|          |                             | (72)発明者 鶴岡 哲明                  |
|          |                             | 神奈川県川崎市中原区上小田中4丁目1番            |
|          |                             | 1号 富士通株式会社内                    |
|          |                             | (74)代理人 100103171              |
|          |                             | <b>弁理士 雨貝 正彦</b>               |
|          |                             | 最終頁に続く                         |

### (54) 【発明の名称】 パケット処理装置

#### (57)【要約】

【課題】 高速なパケット処理が可能であり、しかもパケットのデータ長に依存しない数の命令手順を有するパケット処理を行うことができるパケット処理装置を提供すること。

【解決手段】 パケット処理プロセッサ100は、パケットアクセス機構110、中間データ転送機構120、選択信号生成部130、複数の命令手順実行部140、150、160を含んで構成されている。選択信号生成部130は、外部からパケット到着信号が入力されると、3つの命令手順実行部140、150、160のそれぞれに向けて選択的かつ巡回的に個別選択信号を出力する。個別選択信号を受け取った各命令手順実行部は、受信パケットに対する所定のパケット処理を開始する。



1

#### 【特許請求の範囲】

【請求項1】 命令を実行することにより所定のパケット処理を行うパケット処理プロセッサを有するパケット処理装置であって、

前記パケット処理プロセッサは、

複数の第1のレジスタを含んで構成されており、受信したパケットデータを先頭から順に前記第1のレジスタ間でシフトして伝送するパケットアクセス機構と、

前記パケットアクセス機構内の前記第1のレジスタに保持された前記パケットデータに基づいて、複数のパケッ 10トのそれぞれに対応する所定の演算を並列に実行する複数の命令手順実行部と、

前記パケットの受信タイミングに同期して、このパケットに対応する前記演算を行う前記命令手順実行部を選択する選択信号を生成する選択信号生成部と、

を備えることを特徴とするパケット処理装置。

【請求項2】 請求項1において、

複数の第2のレジスタを含んで構成されており、前記パケットアクセス機構内の前記第1のレジスタを用いた前記パケットデータのシフト動作に同期して、前記パケットデータに対応する前記命令手順実行部による処理結果である中間データを前記第2のレジスタ間でシフトして転送する中間データ転送機構をさらに備えることを特徴とするパケット処理装置。

【請求項3】 請求項1または2において、

前記第1および第2のレジスタの少なくとも一方について、外部から入力されるデータの書き込み位置を可変に 設定する書き込み位置設定機構を備えることを特徴とするパケット処理装置。

【請求項4】 請求項1または2において、

前記第1および第2のレジスタの少なくとも一方について、外部に出力するデータの読み出し位置を可変に設定する読み出し位置設定機構を備えることを特徴とするパケット処理装置。

【請求項5】 請求項1~4のいずれかにおいて、 直列に接続された複数の前記パケット処理プロセッサを 有することを特徴とするパケット処理装置。

【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、パケット中継装置 等において、入力されるパケットデータに対して所定の パケット処理を行うパケット処理装置に関する。

[0002]

【従来の技術】従来から、ネットワークを介して接続された端末間の通信が盛んであり、特に最近では、ネットワーク規模の拡大に伴ってネットワーク間の中継を行う必要が生じている。例えば、LAN (Local Area Network) とLAN、あるいはLANと専用線を相互接続したネットワークが構築されている。特に最近では、IP (Internet Protocol) によるネットワークが主流とな

っている。IPはISO (International Organization for Standardization) のOSI (Open System Interconnection) モデルにおけるネットワーク層に相当するコネクションレス型のプロトコルである。あらかじめ端末間で通信路を確保する場合に用いられるコネクション型のプロトコルと異なり、コネクションレス型のIP通信では、LAN間を相互接続するパケット中継装置が、通信データが含まれるパケットを中継処理することによって端末間の通信が実現する。IPネットワークおける中継処理では、宛先テーブルの検索やヘッダ書き換え処理等の各種のパケット処理が必要になる。

【0003】上述したパケット中継装置において行われるパケット処理には、パケット・ヘッダのチェックサムの計算、宛先テーブルの検索、パケット・ヘッダの書き換え等のパケットを中継するために必要な各種の処理に加え、ネットワークにおける通信を制限するパケットフィルタリングの処理が含まれる。これらの処理は専用のハードウェアで行うには煩雑であり、従来はプロセッサを用いたソフトウェア処理によって実現していた。

【0004】図10は、プロセッサを用いてパケット処理を行う従来のパケット処理装置の構成を示す図である。図10に示すように、従来のパケット処理装置は、プロセッサ900とメモリ910とがバス920を介して接続されている。このような構成においてプロセッサ900がメモリ910内に格納されたパケットを読み出すことにより、パケット中継装置における各種のパケット処理が実行される。

[0005]

【発明が解決しようとする課題】ところで、上述したプ ロセッサ900を用いた従来のパケット処理装置では、 メモリ910に対するパケットデータの読み出し処理や 書き込み処理が頻繁に行われるため、パケット処理の高 速化が難しいという問題があった。すなわち、プロセッ サ900は、パケットデータをメモリ910に格納した 後、この格納されたパケットデータを適時読み出してそ の内容に対して所定の処理を実行し、さらにその処理結 果をメモリ910に書き込む必要がある。また、プロセ ッサ900は、メモリ910に対して読み出しアドレス を与えてから、格納されたパケットデータの読み出しを 行う。同様に、プロセッサ900は、メモリ910に対 して書き込みアドレスを与えてから、パケットデータの 書き込みを行う。このとき、プロセッサ900がメモリ 910に対してアドレスを与えてからデータの読み出し や書き込みが可能になるまでに、プロセッサ900のサ イクルタイムと比較して時間がかかる。

【0006】また、逐次実行型のプロセッサ900は、 同時に実行できる処理が単一であって読み出し動作と書 き込み動作を同時に実行できないことや、メモリ910 に対しても読み出しと書き込みの同時動作ができる回路 50 は作りにくいことなどに起因して、通常はメモリ910 に対して、プロセッサ900によるパケットデータの読 み出しと書き込み動作を同時に行うことができない。

【0007】このように、メモリ910に対するパケッ トデータの読み出し/書き込み処理のオーバヘッドが、 プロセッサ900とメモリ910との間のパケットデー タの転送処理において障害となり、パケット処理を高速 に行うことができなかった。また、上述したプロセッサ 900を用いた従来のパケット処理装置では、1つのパ ケットに対して許容される処理時間が、連続して受信さ れる2つのパケットの受信間隔に依存するため、パケッ トのデータ長が最も短い場合に許容される処理時間が短 くなり、実行可能な命令手順のステップ数が少なくなる という問題があった。上述したメモリ910に処理待ち のパケットデータを格納しておくことにより、データ長 が短いパケットが一時的に送られてきた場合に処理時間 の調整を行うことは可能であるが、このようなデータ長 が短いパケットが多数連続して送られてくると、未処理 のパケットデータが徐々に増加して、メモリ910がオ ーバーフローする事態が生じる。このため、どのような パケットが送受信される場合であっても、パケットのデ ータ長に依存せずに多くの命令手順を実行可能なパケッ ト処理装置が望まれている。

【0008】本発明は、このような点に鑑みて創作されたものであり、その目的は、高速なパケット処理が可能であり、しかもパケットのデータ長に依存しない数の命令手順を有するパケット処理を行うことができるパケット処理装置を提供することにある。

#### [0009]

【課題を解決するための手段】上述した課題を解決する ために、本発明のパケット処理装置は、命令を実行する ことにより所定のパケット処理を行うパケット処理プロ セッサを有しており、このパケット処理プロセッサは、 パケットアクセス機構と複数の命令手順実行部と選択信 号生成部を備えて構成されている。パケットアクセス機 構は、複数の第1のレジスタを含んでおり、受信したパ ケットデータを先頭から順にこれら第1のレジスタ間で シフトして伝送する。複数の命令手順実行部のそれぞれ は、パケットアクセス機構内の第1のレジスタに保持さ れたパケットデータに基づいて、複数のパケットのそれ ぞれに対応する所定の演算を並列に実行する。選択信号 生成部は、パケットの受信タイミングに同期して、この パケットに対応する演算を行う命令手順実行部を選択す る選択信号を生成する。連続してパケットが入力された ときに、各パケットに対応する演算を行う命令手順実行 部が順番に選択されて並列処理が行われるため、データ 長が短いパケットが受信されるような場合であっても、 このパケットのデータ長に依存しない各命令手順実行部 の演算時間を確保することができ、多くの命令手順が実 行可能になる。また、パケットアクセス機構を用いてパ ケットデータの保持および転送を行っており、各命令手 50 順実行部とパケットアクセス機構内の第1のレジスタとの間で、演算の対象となるパケットデータの読み書きが行われるため、従来のパケット処理装置のように、プロセッサとメモリとの間でパケットデータの読み書きを行う場合に生じるオーバーヘッドを低減することができ、パケットデータの読み書き動作も含めた演算処理の高速化が可能になる。

【0010】また、パケットアクセス機構におけるパケットデータのシフト動作に同期して、命令手順実行部による処理結果である中間データを複数の第2のレジスタ間でシフトして転送する中間データ転送機構をさらに備えることが望ましい。演算処理において発生した中間データを演算途中で保持したり最終的に外部に出力する必要がある場合に、これらの中間データをメモリに書き込んだ後に読み出す場合に生じるオーバーヘッドを低減することができるため、中間データに関する一連の動作も含めた演算処理の高速化が可能になる。

【0011】また、上述したパケットアクセス機構は、複数の第1のレジスタに保持されたパケットデータを選択的に取り出して命令手順実行部に入力する第1のセレクタと、命令手順実行部によって特定の命令手順を実行したときに得られる結果データをこの命令手順の実行順序に対応した第1のレジスタに入力する第2のセレクタとを備えることが望ましい。第1および第2のセレクタを備えることにより、複数の第1のレジスタ間を順次シフトされるパケットデータを必要に応じて読み出して各命令手順実行部に入力したり、あるいは、各命令手順実行部から出力されたデータをいずれかの第1のレジスタに書き込むことができ、各命令手順実行部とパケットアクセス機構との間のパケットデータの入出力動作を効率よく行うことができる。

【0012】また、上述した中間データ転送機構は、複数の前記第2のレジスタに保持された中間データを選択的に取り出して命令手順実行部に入力する第3のセレクタと、命令手順実行部によって特定の命令手順を実行したときに得られる中間データを、この命令手順の実行順序に対応した第2のレジスタに入力する第4のセレクタとを備えることが望ましい。第3および第4のセレクタを備えることにより、複数の第2のレジスタ間を順次シフトされる中間データを必要に応じて読み出して各命令手順実行部に入力したり、あるいは、各命令手順実行部から出力された中間データをいずれかの第2のレジスタに書き込むことができ、各命令手順実行部と中間データ転送機構との間の中間データの入出力動作を効率よく行うことができる。

【0013】また、上述した複数の命令手順実行部のそれぞれは、複数の命令手順を順番にデコード処理する制御部と、この制御部によるデコード処理結果に対応する所定の演算処理を行う演算器と、この演算器の作業領域となる複数の汎用レジスタからなる汎用レジスタ群とを

備えている。そして、一のパケットに対応する処理を行うために用意される複数の命令手順の数を、2つのパケットの最小受信間隔よりも長い時間に相当する数に設定することが望ましい。複数の命令手順実行部による演算処理が並行して行われるため、一のパケットに対する演算処理を開始することができるため、各命令手順実行部が実行対象とする命令手順の数を、2つのパケットの最小受信間隔よりも長い時間に相当する数に設定することができ、複雑なパケット処理の実施が可能になる。

【0014】また、上述した第1および第2のレジスタの少なくとも一方について、外部から入力されるデータの書き込み位置を可変に設定する書き込み位置設定機構を備えることが望ましい。少ない数の命令手順で演算が終了するような場合に、パケットアクセス機構や中間データ転送機構の中段のレジスタにパケットデータや中間データを入力することにより、パケットアクセス機構や中間データ転送機構に各種のデータが入力されてから出力されるまでの時間を短くすることができる。

【0015】また、上述した第1および第2のレジスタの少なくとも一方について、外部に出力するデータの読み出し位置を可変に設定する読み出し位置設定機構を備えることが望ましい。少ない命令手順で演算が終了するような場合に、パケットアクセス機構や中間データ転送機構の中段のレジスタからパケットデータや中間データを取り出すことにより、パケットアクセス機構や中間データ転送機構に各種のデータが入力されてから出力されるまでの時間を短くすることができる。

【0016】また、複数のパケット処理プロセッサを複数個直列に接続することによりパケット処理装置を構成することが望ましい。一のパケット処理プロセッサ内の命令手順実行部の数をあまり多くすると各命令手順実行部とパケットアクセス機構や中間データ転送機構との間の配線が複雑になり、信号の遅延時間が長くなって好ましくない場合もある。これに対し、複数の命令手順実行部を有するパケット処理プロセッサを複数個直列に接続することにより、遅延時間を増加させることなく、多くの命令手順を有するパケット処理を一のパケットに対して行うことが可能になる。

## [0017]

【発明の実施の形態】図1は、本発明を適用した第1の実施形態のパケット処理プロセッサの概略的な構成を示す図である。図1に示すように、本実施形態のパケット処理プロセッサ100は、パケットアクセス機構110、中間データ転送機構120、選択信号生成部130、複数(例えば3つ)の命令手順実行部140、150、160を含んで構成されている。

【0018】パケットアクセス機構110は、外部から 入力されるパケットデータを取り込んで保持するととも に、この保持されたパケットデータの部分的な読み出し 50

や、部分的な書き換えを行うために用いられる。このた めに、パケットアクセス機構110は、縦続接続された 複数(例えば24個)のレジスタp0~p23を含んで 構成されている。外部から入力されたパケットデータ は、先頭から所定ビットを単位として順番に各レジスタ p0~p23に取り込まれ、転送される。例えば、各レ ジスタp0~p23に保持される1ワード分のデータの ビット数を「32」とすると、外部から入力されたパケ ットデータが32ビット単位で初段のレジスタp23に 10 取り込まれ保持される。2段目以降の各レジスタp22 ~p0は、初段のレジスタp23に取り込んで保持した 部分的なパケットデータを順番にシフトして保持する。 このようなシフト動作の途中において、各命令手順実行 部140、150、160からパケットデータが読み出 されるとともに、各命令手順実行部140、150、1 60から出力されるデータを、転送中の部分的なパケッ トデータに置き換える処理が行われる。そして、最終段 (24段目)のレジスタ p O からは、パケット処理プロ セッサ100による所定のパケット処理が終了したパケ ットデータが出力される。

【0019】また、中間データ転送機構120は、パケ ットデータに関連する各種の処理結果の保持、転送を行 うために用いられ、縦続接続された複数(例えば24 個)のレジスタe0~e23を含んで構成されている。 これらのレジスタの個数は、上述したパケットアクセス 機構110に含まれるレジスタ p 0~ p 23の数と一致 するように設定されている。例えば、パケットデータに 関連する各種の処理結果が外部から入力されて初段のレ ジスタe23に保持されると、2段目以降の各レジスタ e22~e0は、この初段のレジスタe23に取り込ん で保持した処理結果を順番にシフトして保持する。この ようなシフト動作の途中において、各命令手順実行部1 40、150、160によってこの処理結果が読み出さ れるとともに、各命令手順実行部140、150、16 0から新たな処理結果が出力されていずれかのレジスタ に書き込まれる。

【0020】選択信号生成部130は、外部からパケット到着信号が入力されると、3つの命令手順実行部140、150、160のいずれかに対して、命令手順実行動作の開始を指示する個別選択信号を出力する。例えば、選択信号生成部130は、最初のパケット到着信号が入力されると命令手順実行部140に向けて個別選択信号を出力し、2番目のパケット到着信号が入力されると命令手順実行部150に向けて個別選択信号を入力し、3番目のパケット到着信号が入力されると命令手順実行部160に向けて個別選択信号を入力する。個別選択信号の入力が3つの命令手順実行部140、150、160に対して順番に行われた後、4番目のパケット到着信号が入力されると、選択信号生成部130は、再び命令手順実行部140に向けて個別選択信号を入力す

る。このようにして、3つの命令手順実行部140、150、160に対する個別選択信号の入力動作が所定の順番に沿って巡回的に行われる。

【0021】命令手順実行部140は、個別選択信号の入力タイミングに同期して、パケットアクセス機構110に入力されたパケットデータに対する所定のパケット処理を行う。このために、命令手順実行部140は、演算器141、汎用レジスタ群142、命令手順格納部143を含んで構成されている。演算器141は、命令手順格納部143に格納されている複数の命令を順番に読りみ出して実行することにより、所定の演算を実行する。汎用レジスタ群142は、複数(例えば8個)の汎用レジスタ下0~r7を含んでおり、これらの各汎用レジスタが必要に応じて演算器141の作業領域として用いられる。命令手順格納部143は、演算器141が実行する一連の命令を格納する。例えば、30ステップ分の命令が格納されている。

【0022】同様に、命令手順実行部150は、演算器151、汎用レジスタ群152、命令手順格納部153を含んで構成されている。命令手順実行部160は、演算器161、汎用レジスタ群162、命令手順格納部163を含んで構成されている。これら命令手順実行部150、160は、上述した命令手順実行部140と基本的に同じ構成を有しており、その詳細な説明は省略する。

【0023】図2は、図1に示すパケット処理プロセッサを含むパケット中継装置の構成図である。図2に示すパケット中継装置200は、複数のLAN300のそれぞれに対応するように設けられたパケット処理装置100A、受信インタフェース210、ビットアライメント整合送出器220と、パケット・ヘッダ内の宛先アドレスに基づいて所定のルーティング処理を行うスイッチ部230と、スイッチ部230から送出されたパケットを対応するいずれかのLAN320に送信する複数の送信インタフェース240とを含んで構成されている。

【0024】受信インタフェース210は、パケット中継装置200をLAN300に接続するためのものであり、LAN300を介して送られてくるパケットを受信する。ビットアライメント整合送出器220は、受信インタフェース210によって受信されたパケットを先頭40から順番に所定ビットずつ分割して、パケット中継装置200内での処理単位となる1ワード単位のパケットデータを生成するためのものであり、この分割処理がなされた所定ビット数単位のパケットデータがパケット処理装置100Aに入力される。例えば、本実施形態では、パケット中継装置200内で1ワードを32ビットとした処理が行われており、ビットアライメント整合送出器220は、入力されるパケットデータを32ビットずつに分割する。また、ビットアライメント整合送出器220は、受信インタフェース210によって受信された新50

たなパケットが入力されると、パケットの到着を示す所 定のパケット到着信号をパケット処理装置 1 0 0 A に向 けて出力する。

【0025】パケット処理装置100Aは、ビットアライメント整合送出器220から出力されるパケットデータに基づいて所定のパケット処理を行う。本実施形態では、図1に示したパケット処理プロセッサ100によってパケット処理装置100Aが構成されている。

【0026】パケット処理装置100Aを構成するパケット処理プロセッサ100では、ビットアライメント整合送出器220からパケット到着信号が入力されると、選択信号生成部130から3つの命令手順実行部140、150、160のいずれかに向けて、巡回的に個別選択信号を出力する。この個別選択信号が入力された命令手順実行部140、150、160は、チェックサムの計算、宛先テーブルの検索、パケット・ヘッダの書き換え等の各種のパケット処理を、ビットアライメント整合送出器220から出力される各受信パケットのパケットデータに対して行った後、この各種のパケット処理がなされた後のパケットをスイッチ部230に向けて出力する。

【0027】図3は、IPv4(バージョン4)に対応するパケットのフォーマットを示す図である。図3に示すように、IPv4に対応するパケット・ヘッダには、Version(バージョン)、IHL(Internet Header Length、ヘッダ長)、Type of Service(タイプオブサービス)、Total Length(全長)、Identification(識別名)、Flags(フラグ)、Fragment Offset(断片オフセット)、Time to Live(寿命)、Protocol(プロトコル)、Header Checksum(ヘッダチェックサム)、Source Address(送信元アドレス)、Destination Address(宛先アドレス)が含まれている。

【0028】上述したように、パケット・ヘッダの特定の位置にパケットを中継するために必要な各種のデータが含まれており、パケット処理プロセッサ100は、このパケット・ヘッダを含むパケットデータの全体を所定ビット数を単位として先頭からパケットアクセス機構110のレジスタp23~p0に順に取り込んで保持することにより、各種のパケット処理に必要な特定のデータを読み出したり、あるいは特定のデータを書き換えたりしている。なお、図3には、パケット・ヘッダに続くデータ領域に4ワード分の通信データが格納されている場合が示されており、本実施形態では5ワード分のパケット・ヘッダと4ワード分の通信データを含む9ワード分のパケットデータが、最も小さなサイズのパケットに対応しているものとする。

【0029】このように、本実施形態のパケット処理プロセッサ100では、パケットが受信されてビットアライメント整合送出部220からパケット到着信号が出力される毎に、選択信号生成部130から命令手順実行部

140、150、160に対して選択的かつ巡回的に個別選択信号を入力しており、命令手順実行部140、150、160のいずれかによるパケット処理が開始される。したがって、各命令手順実行部は、一のパケットに対応するパケット処理を、3つ先のパケットが到着するまでの間に終了させればよく、一のパケットに対して許容可能なパケット処理のステップ数を多く設定することができる。

【0030】例えば、図3に示した最小サイズのパケットが連続して受信された場合の最小パケット間隔(最小 10 受信間隔)において実行可能な命令手順の数を n とすると、本実施形態のパケット処理プロセッサ 100では、3つの命令手順実行部 140、150、160のそれぞれにおいて一のパケットに対して許容可能な命令手順の数を 3 n とすることができるため、パケット処理プロセッサ 100は、受信パケットのサイズ(パケットのデータ長)に依存しない数の命令手順を有するパケット処理を行うことが可能になる。

【0031】次に、本実施形態のパケット処理プロセッサ100の詳細な構成および動作の具体例について説明 20 する。図4は、パケット処理プロセッサ100の詳細な構成を示す図である。図4に示すように、パケットアクセス機構110は、パケットデータを先頭からワード単位(32ビット単位)で順番に保持する上述した24個のレジスタp0~p23のそれぞれの前段に設けられた24個のセレクタ(S)10と、レジスタp0~p23のそれぞれの出力データを選択するセレクタ(S)12とを含んで構成されている。

【0032】レジスタp23の前段に設けられた初段のセレクタ10は、パケットアクセス機構110に入力された32ビットのパケットデータと、3つの命令手順実行部140、150、160のそれぞによって所定の命令手順を実行したときに得られる3つの結果データとが入力されており、これら4つのデータの中からいずれかを選択してレジスタp23に向けて出力する。レジスタp23は、このようにして前段のセレクタ10から出力されたデータを、クロック信号の次の立ち上がりに同期して取り込んで保持する。

【0033】また、レジスタp22とレジスタp23の 40間に設けられた2段目のセレクタ10は、レジスタp23から出力されるデータと、3つの命令手順実行部140、150、160のそれぞによって所定の命令手順を実行したときに得られる3つの結果データとが入力されており、これら4つのデータの中からいずれかを選択してレジスタp22に向けて出力する。レジスタp22は、このようにして前段のセレクタ10から出力されたデータを、クロック信号の次の立ち上がりに同期して取り込んで保持する。

【0034】同様に、3段目以降の各セレクタ10は、

前段に接続されたレジスタから出力されるデータと、3 つの命令手順実行部140、150、160のそれぞれ によって所定の命令手順を実行したときに得られる3つ の結果データとが入力されており、これら4つのデータ の中からいずれかを選択して後段のレジスタに向けて出 力する。この後段のレジスタは、このようにして前段の セレクタ10から出力されたデータを、クロック信号の 次の立ち上がりに同期して取り込んで保持する。

【0035】また、24個のレジスタp0~p23の出力側に共通に接続されたセレクタ12は、各レジスタp0~p23から出力されるデータが入力されており、その中からそれぞれ最大2個ずつを選択して、命令手順実行部140、150、160に向けて出力する。

【0036】また、図4に示すように、中間データ転送機構120は、中間データを保持する上述した24個のレジスタe0~e23の他に、これらのレジスタe0~e23のそれぞれの前段に設けられた24個のセレクタ(S)20と、レジスタe0~e23のそれぞれの出力データを選択するセレクタ(S)22とを含んで構成されている。この中間データ転送機構120は、上述したパケットアクセス機構110と基本的に同じ構成を有している。

【0037】すなわち、レジスタp23の前段に設けられた初段のセレクタ20は、中間データ転送機構120に入力された中間データと、3つの命令手順実行部140、150、160のそれぞれによって所定の命令手順を実行したときに得られる3つの中間データとが入力されており、これら4つの中間データの中からいずれかを選択してレジスタe23に向けて出力する。レジスタe23は、このようにして前段のセレクタ20から出力されたデータを、クロック信号の次の立ち上がりに同期して取り込んで保持する。

【0038】また、レジスタe22とレジスタe23の間に設けられた2段目のセレクタ20は、レジスタe23から出力される中間データと、3つの命令手順実行部140、150、160のそれぞれによって所定の命令手順を実行したときに得られる3つの中間データとが入力されており、これら4つの中間データの中からいずれかを選択してレジスタe22に向けて出力する。レジスタe22は、このようにして前段のセレクタ20から出力されたデータを、クロック信号の次の立ち上がりに同期して取り込んで保持する。

【0039】同様に、3段目以降の各セレクタ20は、前段に接続されたレジスタから出力される中間データと、3つの命令手順実行部140、150、160のそれぞによって所定の命令手順を実行したときに得られる3つの中間データとが入力されており、これら4つの中間データの中からいずれかを選択して後段のレジスタに向けて出力する。この後段のレジスタは、このようにして前段のセレクタ20から出力された中間データを、ク

ロック信号の次の立ち上がりに同期して取り込んで保持 する。

11

【0040】また、24個のレジスタe0~e23の出 力側に共通に接続されたセレクタ22は、各レジスタe 0~e23から出力される中間データが入力されてお り、その中からそれぞれ最大2個ずつを選択して、命令 手順実行部140、150、160に向けて出力する。 【0041】なお、本実施形態では、パケットアクセス 機構110に含まれるレジスタ p0~p23の数と中間 データ転送機構120に含まれるレジスタe0~e23 の数とを一致させており、しかも各レジスタは同じクロ ック信号に同期してデータの取り込みを行うように設定 されている。このため、パケットデータがパケットアク セス機構110内の各レジスタ間を順にシフトして所定 のパケット処理が行われているときに、そのパケット処 理で生じた中間データもこのパケット処理に同期して中 間データ転送機構120内を順にシフトするようになっ ている。

【0042】また、図4に示すように、命令手順実行部 140は、パケットアクセス機構110に入力されたパ 20 ケットデータに対して所定のパケット処理を行うため に、上述した演算器141、汎用レジスタ群142の他 に、各命令手順を入力順にデコードする命令デコーダ4 0を含む制御部42と、演算器141の処理ステップ数 をカウントするプログラムカウンタ44と、演算器14 1による演算結果の各状態を保持するフラグ・レジスタ 46とを含んで構成されている。また、汎用レジスタ群 142は、8個の汎用レジスタr0~r7の中からデー タの入力先となる汎用レジスタを切り替える入力セレク タ48と、データの読み出し元となる汎用レジスタを切 30 り替える出力セレクタ49とを含んで構成されている。 【0043】制御部42内の命令デコーダ40は、クロ ック信号に同期して入力される一連の命令手順を順番に デコード処理する。制御部42は、この処理結果に基づ いて、命令手順実行部140内の他の構成部やパケット アクセス機構110内のセレクタ10、12あるいは中 間データ転送機構120内のセレクタ20、22に対し て、必要に応じて動作指示を与える。

【0044】なお、図4では、これらの動作指示を行うために必要な制御線が省略されており、各構成部間のデ 40 ータ線のみが示されている。例えば、ある命令手順が実行されたときに、汎用レジスタr0に格納されたデータとレジスタp23に格納されたデータとを加算し、その結果をレジスタr0に格納する処理が行われる場合を考える。この命令手順が命令デコーダ40によってデコード処理されると、制御部42は、まず出力セレクタ49を制御して汎用レジスタr0のデータを演算器141の一方の入力端子に向けて出力するとともに、パケットアクセス機構110内のセレクタ12を制御してレジスタp23のデータを演算器141の他方の入力端子に向け 50

て出力する。次に、制御部42は、演算器141を制御して2つの入力端子に入力されたデータ同士を加算し、その後入力セレクタ48と汎用レジスタr0を制御して、この加算結果を汎用レジスタr0に格納する。

12

【0045】また、図1に示した構成例では、一連の命令手順を命令手順実行部140内の命令手順格納部143に格納したが、これらの命令手順の保持方法については各種の変形が考えられる。例えば、命令手順実行部140の外部あるいはパケット処理プロセッサ100の外部にメモリ(図示せず)を設けておいて、パケット処理の実施に先立ってこれらの命令手順を順番に読み出すようにしてもよい。

【0046】また、図4において、他の2つの命令手順 実行部150、160は、上述した命令手順実行部14 0と基本的に同じ構成を有しており、同じ命令手順が入 力された場合の動作も命令手順実行部140の対応する 動作と同じである。したがって、入力されるパケットデ ータに対して、どの命令手順実行部140、150、1 60がパケット処理を行った場合であっても同じ処理結 果を得ることができる。

【0047】図5は、各命令手順実行部140、150、160内の制御部42に入力される命令の具体例を示す図である。また、図6は、図5に示した命令セット(命令の種類)を用いて構成される一連の命令手順を示す図であり、一例としてパケット・ヘッダのチェックサムを計算する場合のプログラムが示されている。

【0048】これらの図に示すように、本実施形態のパ ケット処理プロセッサ100で実行される各命令の種類 は、非実行、データ転送、整数演算、論理演算、ビット 演算に大別される。また、本実施形態では、図6に示す ように、各命令を記述するときに用いる命令フォーマッ トに関しては、「MOVE」等で表現される命令ニモニ ックの前に必ず条件コードがつくように各命令手順の表 記ルールが設定されている。パケット処理プロセッサ1 00は、直前の命令の演算結果がこの条件コードで示さ れる条件を満たす場合に、この条件コードの次に記述さ れた命令を実行する。例えば、パケット処理プロセッサ 100が実行した直前の命令の演算結果が0である場合 を考えると、パケット処理プロセッサ100は、現在実 行しようとしている命令の条件コードが「=」(0に等 しい)ならばこの命令を実行し、それ以外の条件コード が付されている場合にはその命令を実行せずに単にクロ ックに同期した時間のみが経過する。このような条件コ ードとしては、例えば「=」以外に、「≠」(0と等し くない)、「<」(0より小さい)、「>」(0より大 きい) 「A」(常に実行(Always))がある。各命令手 順実行部140、150、160は、直前に実行した命 令に対応する演算結果に対して、各条件コードの真偽を 評価可能な(各条件コードを満たすか否かを判定可能 な)数の評価フラグをフラグ・レジスタ46として有し

(8)

14

ている。また、各命令手順実行部140、150、16 0内の各フラグ・レジスタ46には、キャリーを考慮し た加算命令「ADC」を実行したときに生じるキャリー を保持するキャリーフラグも含まれている。

13

【0049】また、各命令のフォーマットは、オペランドの数によって2種類存在する。3つのオペランドを有する命令のフォーマットは、条件コード、命令ニモニック、ディスティネーション・オペランド、ソース・オペランド1、ソース・オペランド2となる。また、2つのオペランドを有する命令のフォーマットは、条件コード、命令ニモニック、ディスティネーション・オペランド、ソース・オペランド1となる。

【0050】次に、図6に示した一連の命令手順を実行する場合のパケット処理プロセッサ100の動作を説明する。なお、パケット・ヘッダのチェックサムを計算するパケット処理を実行する前に、図6に示した一連の命令手順(例えば、命令手順実行部140の場合は、通し番号1~11に対応する11個の命令手順)が順番に制御部42に入力され、命令デコーダ40によって各命令手順に対するデコード処理が行われる。これらのデコー20ド処理結果が制御部42内に保持されており、1クロック毎に一つの命令手順に対応した演算が演算器141によって実施される。

【0051】パケット中継装置200によってパケットが受信され、ビットアライメント整合送出器220からパケット到着信号がパケット処理装置100Aを構成するパケット処理プロセッサ100に入力されると、選択信号生成部130は、命令手順実行部140に向けて個別選択信号を出力する。以後、命令手順実行部140内の演算器141によるパケット・ヘッダのチェックサムの計算が開始される。なお、このタイミングで、受信パケットの先頭データ(先頭の32ビットデータa0)がパケットアクセス機構110の初段のレジスタp23に格納される。

### 【0052】順序1 (通し番号1)

まず、演算器141は、順序1において、パケット・ヘッダの先頭データが格納されているパケットアクセス機構110内の初段のレジスタp23の内容を、内蔵された汎用レジスタ群142に含まれる汎用レジスタr0に転送する。

#### 【0053】順序2(通し番号2)

演算器141は、次のクロック信号に同期して、レジスタp23の内容と、汎用レジスタr0の内容とを加算し、この加算結果を汎用レジスタr0に格納する。このとき、直前のクロック信号に同期して上述した順字1においてレジスタp23に格納されたパケットの先頭データは次段のレジスタp23にはあらたにIPヘッダの次のデータが格納されている。すなわち、この順字2によって実行される加算処理によって、パケットの先頭の1ワード分のデ50

ータと次の1ワード分のデータとが加算され、その結果 が汎用レジスタr0に格納される。

【0054】順字3 (通し番号3) ~順字5 (通し番号5)

以後同様にして、順字3~5における加算処理が繰り返され、パケットの先頭から5ワード目までの各データが加算される。

## 順序6(通し番号6)

次に、演算器141は、即値0と、汎用レジスタr0の内容と、直前の順字5の加算処理において発生したキャリーとを加算し、この加算結果を汎用レジスタr0に格納する。なお、即値とは、汎用レジスタ群142内の各汎用レジスタやパケットアクセス機構110内の各レジスタを指定するのではなく、値そのものを指定するものであり、図6では「\$」で表現されている。すなわち、\$0とは即値として指定される値「0」を示し、\$16とは即値として指定される値「16」を示す。

【0055】順序2~6で実行される加算処理によって、パケットヘッダを構成する各ワードのデータについて、キャリーを考慮した加算処理が行われ、この加算結果が汎用レジスタr0に格納される。

#### 順序7 (通し番号7)

演算器 141は、汎用レジスタr 0の内容を汎用レジスタr 1に転送する処理を実行する。

#### 【0056】順序8 (通し番号8)

演算器141は、汎用レジスタr0のデータを16ビット右に(下位ビット側に)シフトし、空いた上位ビット側に"0"を詰めたデータを求め、その結果を汎用レジスタr0に格納する処理を実行する。この順序8と一つ前の順序7の処理によって、順序6までの加算処理によって得られた32ビットデータの上位16ビットと下位16ビットが、汎用レジスタr0、r1のそれぞれに格納される。

## 【0057】順序9 (通し番号9)

演算器 141は、汎用レジスタr0の内容と汎用レジスタr1の内容とを半ワード(本実施形態では16ビット)単位で加算し、この加算結果を汎用レジスタr0に格納する。

### 【0058】順序10 (通し番号10)

(0) 演算器141は、汎用レジスタr0に格納されたデータを半ワード単位で反転させ、その結果を汎用レジスタr0に格納する。この処理によって、汎用レジスタr0の内容に対して1の補数を求める演算が行われる。

#### 【0059】順序11 (通し番号11)

条件コードが「≠」なので、演算器 141は、順字10 における処理結果が0でない場合には、即値1(\$1)を中間データ転送機構120内のレジスタe13に格納する処理を行う。また、演算器 141は、順字10における処理結果が0の場合には、即値1をレジスタe13に格納する処理を行わない。

40

る。

【0060】なお、順序1~11の各順字の命令手順が実行される動作と並行して、パケットアクセス機構110に入力されたパケットデータがレジスタp23、p22、…と順番にシフトされるため、順序11の命令手順が実行されるタイミングでは、パケット・ヘッダのチェックサムの計算対象となっているパケットの先頭のパケットデータがレジスタp13に格納される。

【0061】次のクロック信号に同期して、パケット処理プロセッサ100は、中間データ転送機構120内のレジスタe13の内容をレジスタe12にシフトするとともに、パケットアクセス機構110内のレジスタp13に格納された先頭のパケットデータをレジスタp12にシフトする。このようにして、パケットアクセス機構110内の各レジスタ間をパケットデータがシフトする動作に同期して、中間データ転送機構120内の各レジスタ間をチェックサムの計算結果がシフトする動作が行われ、パケット処理プロセッサ100からパケットデータが出力されるタイミングで、このパケットデータに付随する情報として、パケット・ヘッダのチェックサムの計算結果を外部に伝達することができる。

【0062】ところで、本実施形態では、最小パケット間隔が10クロック分であるため、パケットが連続して受信された場合には、最初のパケットに対する命令手順実行部140によるチェックサム計算が終了する前に、次のパケットがパケット中継装置200に到着してしまう。しかし、本実施形態では、2番目に受信されたパケットに対するパケット・ヘッダのチェックサム計算は、命令手順実行部150によって行われるため、2つの受信パケットに対するパケット・ヘッダのチェックサム計算が並行して実施されることになる。例えば、図6に示すように、通し番号11に対応して、命令手順実行部140では順序11の処理が行われているときに、命令手順実行部150では順序1の処理が行われる。

【0063】同様に、2番目の受信パケットに対する命令手順実行部150によるチェックサム計算が終了する前に、3番目のパケットがパケット中継装置200に到着する場合がある。この場合には、例えば、図6に示すように、通し番号21に対応して、命令手順実行部150では順字11の処理が行われているときに、命令手順実行部160では順字1の処理が行われる。

【0064】このように、本実施形態のパケット処理プロセッサ100では、最小パケット間隔に対応して実行可能な命令手順の数が10である3つの命令手順実行部140、150、160を用いて、受信パケットに対する所定のパケット処理を選択的かつ巡回的に行っているため、命令手順実行部140、150、160のそれぞれにおいて実行可能なステップ数を3倍の30ステップに増やすことができる。したがって、パケットの受信間隔に依存しない命令手順を有するパケット処理を行うことができ50

【0065】また、本実施形態のパケット処理プロセッサ100では、順番にパケットデータをシフトしながら各命令手順実行部による読み書きを行うためのパケット

アクセス機構120を内蔵することにより、パケット処理に関してパケット処理プロセッサとメモリとの間のデータの読み書き時に生じるオーバーヘッドを低減することができ、高速なパケット処理が可能になる。

【0066】 [第2の実施形態] 図7は、本発明を適用した第2の実施形態のパケット処理装置の概略的な構成を示す図である。図7に示す本実施形態のパケット処理装置は、総続接続された複数個(例えば6個)のパケット処理プロセッサ100を含んで構成されている。それぞれのパケット処理プロセッサ100は、図4に示した構成を有している。

【0067】本実施形態のパケット処理装置では、6個のパケット処理プロセッサ100のそれぞれに含まれる各パケットアクセス機構110が直列に接続されている。これにより、ビットアライメント整合送出器220から入力されるパケットデータが、各段のパケットアクセス機構110内の各レジスタp0~p23を順番に移動し、最終段(6段目)のパケットアクセス機構110内のレジスタp0からパケット処理装置の外部に出力される。

【0068】同様に、6個のパケット処理プロセッサ100のそれぞれに含まれる各中間データ転送機構120が直列に接続されており、ビットアライメント整合送出器220から入力される中間データが、各段の中間データ転送機構120内の各レジスタe0~e23を順番に移動し、最終段の中間データ転送機構120内のレジスタe0からパケット処理装置の外部に出力される。

【0069】これら6個のパケット処理プロセッサ100は単一の集積回路によって形成されており、それぞれの間の配線はチップ内配線によって接続されているため、前段のパケット処理プロセッサ100から出力されるパケットデータや中間データが次のクロック信号の立ち上がりに同期して、次段のパケット処理プロセッサ100内のパケットアクセス機構110や中間データ転送機構120に取り込むことができるようになっている。

【0070】このように、m個のパケット処理プロセッサ100を直列接続することにより、一つのパケットに対して行われるパケット処理の命令手順の数をm倍に増やすことができる。特に、上述した第1の実施形態で説明したように、一のパケット処理プロセッサ内の命令手順実行部の数を増やすことにより、パケット処理の命令手順の数を増やすことが可能であるが、命令手順実行部の数をあまり多くすると、各命令手順実行部とパケットアクセス機構110や中間データ転送機構120との間の配線が複雑になりすぎて、回路の遅延時間が増えて1クロックで1命令を実行できなくなる場合も生じる。こ

17

のような場合には、命令手順実行部の数を所定の許容数 以下に抑えるとともに、複数のパケット処理プロセッサ 100を直列接続することにより、パケット処理の命令 手順の数を増やすことが望ましい。これにより、回路の 遅延時間を所定値以下に抑えて1クロックで1命令が実 行できるようにするとともに、複雑なパケット処理に必 要な命令手順の数を確保することができる。

【0071】なお、本発明は上記実施形態に限定されるものではなく、本発明の要旨の範囲内において種々の変形実施が可能である。例えば、上述した実施形態では、パケット中継装置200に用いられるパケット処理装置100Aについて説明したが、その他の通信装置に用いられるパケット処理装置に本発明を適用することができる。

【0072】また、上述した実施形態では、受信したI Pパケットに対して所定のパケット処理を行う場合を説明したが、IPパケット以外のパケットに対してパケット処理を行うようにしてもよい。また、上述した各実施形態では、パケット処理プロセッサ100内のパケットアクセス機構110と中間データ転送機構120のそれぞれでは、外部から入力されるパケットデータや中間データが初段のレジスタに入力され、最終段のレジスタから出力されるデータがパケット処理プロセッサ100から外部に出力されるようにしたが、パケットアクセス機構110や中間データ転送機構120のそれぞれの中段のレジスタに外部から入力されたデータを直接格納したり、中段のレジスタに格納されたデータを外部に直接取り出すようにしてもよい。

【0073】図8は、パケット処理プロセッサに含まれ るパケットアクセス機構および中間データ転送機構の変 形例を示す図である。図8に示すパケットアクセス機構 110Aは、図4に示したパケットアクセス機構110 に対して、外部からパケットデータが入力される位置が 変更可能になっている点が異なっている。具体的には、 パケットアクセス機構110Aでは、レジスタp0~p 23のそれぞれの前段に設けられたセレクタ (S) 10 にパケット処理プロセッサ100の外部からパケットデ ータが入力されており、外部から入力されるパケットデ ータをいずれかのセレクタ10によって選択することに より、このセレクタ10の後段に接続されたレジスタに 40 パケットデータを直接入力することができる。同様に、 中間データ転送機構120Aでは、レジスタe0~e2 3のそれぞれの前段に設けられたセレクタ(S)20に パケット処理プロセッサ100の外部から中間データが 入力されており、外部から入力される中間データをいず れかのセレクタ20によって選択することにより、この セレクタ20の後段に接続されたレジスタに中間データ を直接入力することができる。パケットアクセス機構1 10A内の各セレクタ10あるいは中間データ転送機構 120A内の各セレクタ20が書き込み位置設定機構に

対応する。

【0074】したがって、図6に示したIPヘッダのチェックサム計算のように少ないステップ数で演算が終了するような場合に、パケットアクセス機構110Aや中間データ転送機構110Aの中段のレジスタにパケットデータや中間データを入力することにより、パケットアクセス機構110Aや中間データ転送機構120Aに各種のデータが入力されてから出力されるまでの時間(タイムラグ)を短くすることができる。

【0075】図9は、パケット処理プロセッサに含まれ るパケットアクセス機構および中間データ転送機構の他 の変形例を示す図である。 図9に示すパケットアクセス 機構110Bは、図4に示したパケットアクセス機構1 10に対して、各レジスタp0~p23に格納されたデ ータを直接取り出すことができるようになっている点が 異なっている。具体的には、パケットアクセス機構11 0 Bでは、レジスタ p 0~ p 2 3 のそれぞれから出力さ れるデータが後段の各セレクタ(S)10に入力されて いるとともに、このデータがセレクタ14にも入力され ている。セレクタ14は、パケット処理プロセッサの外 部にパケットデータを取り出すレジスタを選択するため のものであり、選択されたレジスタに格納されたパケッ トデータは、後段の各レジスタを通すことなく、このセ レクタ14を通して出力される。同様に、中間データ転 送機構120Bでは、レジスタe0~e23のそれぞれ から出力されるデータが後段の各セレクタ(S)20に 入力されているとともに、このデータがセレクタ24に も入力されている。セレクタ24は、パケット処理プロ セッサの外部に中間データを取り出すレジスタを選択す るためのものであり、選択されたレジスタに格納された 中間データは、後段の各レジスタを通すことなく、この セレクタ24を通して出力される。上述したパケットア クセス機構110B内のセレクタ14あるいは中間デー タ転送機構120B内のセレクタ24が読み出し位置設 定機構に対応する。

【0076】したがって、図6に示したIPヘッダのチェックサム計算のように少ないステップ数で演算が終了するような場合に、パケットアクセス機構110Bや中間データ転送機構110Bの中段のレジスタからパケットデータや中間データを取り出すことにより、パケットアクセス機構110Bや中間データ転送機構120Bに各種のデータが入力されてから出力されるまでの時間を短くすることができる。

【0077】また、上述した実施形態では、パケット処理プロセッサ100内に中間データ転送機構120を設けた場合を説明したが、中間データを外部に出力する必要がないパケット処理を行う場合等においてはこの中間データ転送機構120を省略してもよい。例えば、パケット・ヘッダに含まれる「Time to Live (寿命)」の値から1を減じる処理を行う場合には、入力されるパケッ

トデータに含まれるこの「Time to Live」の値を読み出し、この読み出した値から1を減算し、さらにこの減算結果を元の「Time to Live」の領域に書き込む処理を行う。この処理結果に対応する中間データは特に必要ないため、このようなパケット処理を行う場合には中間データ転送機構120を省略することができる。

【0078】(付記1) 命令を実行することにより所定のパケット処理を行うパケット処理プロセッサを有するパケット処理装置であって、前記パケット処理プロセッサは、複数の第1のレジスタを含んで構成されており、受信したパケットデータを先頭から順に前記第1のレジスタ間でシフトして伝送するパケットアクセス機構と、前記パケットアクセス機構内の前記第1のレジスタに保持された前記パケットデータに基づいて、複数のパケットのそれぞれに対応する所定の演算を並列に実行する複数の命令手順実行部と、前記パケットの受信タイミングに同期して、このパケットに対応する前記演算を行う前記命令手順実行部を選択する選択信号を生成する選択信号生成部と、を備えることを特徴とするパケット処理装置。

【0079】(付記2) 付記1において、複数の第2のレジスタを含んで構成されており、前記パケットアクセス機構内の前記第1のレジスタを用いた前記パケットデータのシフト動作に同期して、前記パケットデータに対応する前記命令手順実行部による処理結果である中間データを前記第2のレジスタ間でシフトして転送する中間データ転送機構をさらに備えることを特徴とするパケット処理装置。

【0080】(付記3) 付記1または2において、前記パケットアクセス機構は、複数の前記第1のレジスタに保持された前記パケットデータを選択的に取り出して前記命令手順実行部に入力する第1のセレクタと、前記命令手順実行部によって特定の命令手順を実行したときに得られる結果データを、この命令手順の実行順序に対応した前記第1のレジスタに入力する第2のセレクタと、を備えることを特徴とするパケット処理装置。

【0081】(付記4) 付記2において、前記中間データ転送機構は、複数の前記第2のレジスタに保持された前記中間データを選択的に取り出して前記命令手順実行部に入力する第3のセレクタと、前記命令手順実行部によって特定の命令手順を実行したときに得られる前記中間データを、この命令手順の実行順序に対応した前記第2のレジスタに入力する第4のセレクタと、を備えることを特徴とするパケット処理装置。

【0082】(付記5) 付記1~4のいずれかにおいて、複数の前記命令手順実行部のそれぞれは、複数の命令手順を順番にデコード処理する制御部と、前記制御部によるデコード処理結果に対応する所定の演算処理を行う演算器と、前記演算器の作業領域となる複数の汎用レジスタからなる汎用レジスタ群と、を備え、一の前記パ 50

ケットに対応する処理を行うために用意される前記複数 の命令手順の数を、2つの前記パケットの最小受信間隔 よりも長い時間に相当する数に設定することを特徴とす るパケット処理装置。

【0083】(付記6) 付記1~5のいずれかにおいて、前記第1および第2のレジスタの少なくとも一方について、外部から入力されるデータの書き込み位置を可変に設定する書き込み位置設定機構を備えることを特徴とするパケット処理装置。

【0084】(付記7) 付記1~5のいずれかにおいて、前記第1および第2のレジスタの少なくとも一方について、外部に出力するデータの読み出し位置を可変に設定する読み出し位置設定機構を備えることを特徴とするパケット処理装置。

【0085】(付記8) 付記1~7のいずれかにおいて、直列に接続された複数の前記パケット処理プロセッサを有することを特徴とするパケット処理装置。

[0086]

【発明の効果】上述したように、本発明によれば、連続してパケットが入力されたときに、各パケットに対応する演算を行う命令手順実行部が順番に選択されて並列処理が行われるため、データ長が短いパケットが受信されるような場合であっても、このパケットのデータ長に依存しない各命令手順実行部の演算時間を確保することができ、多くの命令手順が実行可能になる。

【0087】また、パケットアクセス機構を用いてパケットデータの保持および転送を行っており、各命令手順実行部とパケットアクセス機構内の第1のレジスタとの間で、演算の対象となるパケットデータの読み書きが行われるため、従来のパケット処理装置のように、プロセッサとメモリとの間でパケットデータの読み書きを行う場合に生じるオーバーヘッドを低減することができ、パケットデータの読み書き動作も含めた演算処理の高速化が可能になる。

### 【図面の簡単な説明】

【図1】第1の実施形態のパケット処理プロセッサの概略的な構成を示す図である。

【図2】図1に示すパケット処理プロセッサを含むパケット中継装置の構成図である。

0 【図3】 IP v 4 に対応するパケットのフォーマットを 示す図である。

【図4】本実施形態のパケット処理プロセッサの詳細な構成を示す図である。

【図5】各命令手順実行部内の制御部に入力される命令 の具体例を示す図である。

【図6】図5に示した命令セットを用いて構成される一 連の命令手順を示す図である。

【図7】第2の実施形態のパケット処理装置の概略的な 構成を示す図である。

【図8】パケット処理プロセッサに含まれるパケットア

クセス機構および中間データ転送機構の変形例を示す図 である。

【図9】パケット処理プロセッサに含まれるパケットアクセス機構および中間データ転送機構の他の変形例を示す図である。

【図10】従来のパケット処理装置の構成を示す図である。

#### 【符号の説明】

- 10、12、20、22 セレクタ(S)
- 40 命令デコーダ
- 42 制御部
- 44 プログラム・カウンタ
- 46 フラグ・レジスタ

【図1】

48、49 セレクタ

100 パケット処理プロセッサ

110 パケットアクセス機構

120 中間データ転送機構

140、150、160 命令手順実行部

141、151、161 演算器

142、152、162 汎用レジスタ群

200 パケット中継装置

210 受信インタフェース

10 220 ビットアライメント整合送出器

230 スイッチ部

240 送信インタフェース

300, 320 LAN

【図4】





【図2】

#### パケット中郷技量の構成図



【図3】

IPv4に対応するパケットのフォーマット図



【図7】

## 第2の実施形態のパケット処理装置の概略的な構成図



【図5】

【図6】

#### 命令の具体例

| 日本の名句 | 209ニモニック | 17.F93.MG                                                             |
|-------|----------|-----------------------------------------------------------------------|
| 杂文行   | NOP      | 何もな行せず、クロックのみなごする。                                                    |
| データなど | MOVE     | ワードに近てレジスタごはたはメモリ四でデータに記する。                                           |
|       | WOVW     | ギフードに近(下位ビット()でレジスタ(プでデータ)記する。                                        |
|       | MOVB     | ノイトに位下位ヒットのでレジスタコでデータ运送する。                                            |
| 30510 | ADD      | D-POMO TERMINA                                                        |
|       | ADC      | キャリーとワードのかで、このは中かにする。                                                 |
|       | ADW      | なソードには「の」ということのは、                                                     |
|       | AWC      | キャリーと学フードで位う。この社会がに対る。                                                |
|       | SUB      | D-FORTO COLOREST &                                                    |
|       | SBW      | サンードではついか。日本のこであります。                                                  |
|       | OR       | ワードに対で記録があ                                                            |
| i     | AND      | 7-HCM COULDING                                                        |
|       | XOR      | D-PONTECTAMENTAL                                                      |
|       | NOT      | ワードの行び形態。                                                             |
|       | NTW      | キソードにはである。 半型と下の下のパットなあるしない                                           |
|       | NTB      | マストの日の日本 マストところとはアットは名がしない。                                           |
|       | SFL      | を上位ビットはにシフトレ 下位ピットにのをつめる                                              |
|       | ROTL     | 左0.5.                                                                 |
|       | SFR      | 古(下位ピットロ)にシフトし、上位ピットにの参うかる                                            |
|       | ROTR     | <b>有意</b> 无                                                           |
| ピットロロ | BSF      | ソースオペランドのビットの2017日ピットからだごして、<br>に対応じが1のビットの2018からる。                   |
|       | BSR      | ソースオペランドのピット列の日上がピットからにごして、<br>口根で口が1のピットのひ口を含める。                     |
|       | 8T       | ソースオペランド16ペースとし、ソースオペランド26<br>オフセットとするピットのこ在フラグ・レジスタのキャリー<br>フラグにセット。 |

#### 一口の命令手口の口体句

| D L | П  | 12141の命令手口      |    | 図151の命令手口       | m             | 3월161の命令手口      |
|-----|----|-----------------|----|-----------------|---------------|-----------------|
| 0.8 |    |                 | B  | 69              | QD.           | ୟସ              |
| 1   |    | AMOVE 10 p7     |    |                 |               |                 |
| 2   | 2  | AADO 10 10 p7   |    |                 |               |                 |
| 3   |    | AADC r0 r0 p7   |    |                 |               |                 |
| 4   |    | AADC 10 10 b7   |    |                 |               |                 |
| 5   | 5  | 7a Ot Ot ODAA   |    |                 |               |                 |
| 6   | 6  | AADC 10 10 \$0  |    |                 |               |                 |
| 7   | 7  | AMOVE r1 r0     |    |                 |               |                 |
| 8   | В  | ASFR 10 10 \$16 |    |                 |               |                 |
| 9   | 9  | TO O WOAA       |    |                 |               |                 |
| 10  | 10 | On On WIMA      |    |                 |               |                 |
| 11  | 11 | ≠MOVE e13 \$1   | 1  | AMOVE 10 p7     |               |                 |
| 12  |    |                 | 2  | AADO rO rO p7   |               |                 |
| 13  |    |                 | 3  | AADC 10 10 p7   |               |                 |
| 14  |    |                 | 4  | AADC r0 r0 p7   | $\overline{}$ |                 |
| 15  |    |                 | Б  | AADC 10 10 p7   |               |                 |
| 16  |    |                 | 6  | AADC 10 10 \$0  |               |                 |
| 17  |    |                 |    | AMOVE r1 r0     |               |                 |
| 18  |    |                 | В  | ASFR 10 10 \$16 |               |                 |
| 19  |    |                 | 9  | AADW 10 10 r1   |               |                 |
| 20  |    |                 | 10 | ANTW 10 10      |               |                 |
| 21  |    |                 | 11 | ≠MOVE e13 \$1   | 1             | AMOVE 10 p7     |
| 22  |    |                 |    |                 | 2             | AADD 10 10 p7   |
| 23  |    |                 |    |                 |               | AADC 10 10 p7   |
| 24  |    |                 |    |                 | 4             | AADC 10 10 p7   |
| 25  |    |                 |    |                 | 5             | AADC 10 10 p7   |
| 26  |    |                 |    |                 | 6             | AADC 10 10 SO   |
| 27  |    |                 |    |                 | 7             | AMOVE r1 r0     |
| 28  |    |                 |    |                 | 8             | ASFR r0 r0 \$16 |
| 20  |    |                 |    |                 | 9             | AADW 10 10 r1   |
| 30  |    |                 |    |                 | 10            | ANTW 10 10      |
| 31  |    |                 |    |                 |               | ≠MOVE e13 \$1   |

【図8】



## 【図9】



【図10】



## フロントページの続き

## (72)発明者 梅崎 康之

福岡県福岡市博多区博多駅前三丁目22番8 号 富士通九州デジタル・テクノロジ株式 会社内

## (72)発明者 下園 善知

福岡県福岡市博多区博多駅前三丁目22番8号 富士通九州デジタル・テクノロジ株式 会社内

Fターム(参考) 5K030 GA03 HA08 HD07 JA05 JL07 KA01 KA03 KA13 KX12 KX13 KX17 LE06